package com.papercutting.platform.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.papercutting.platform.dto.query.TutorialQuery;
import com.papercutting.platform.entity.Tutorial;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 教程Mapper接口
 */
@Mapper
public interface TutorialMapper extends BaseMapper<Tutorial> {
    
    /**
     * 分页查询教程列表
     */
    IPage<Tutorial> selectTutorialPage(Page<Tutorial> page, @Param("query") TutorialQuery query);
    
    /**
     * 根据条件查询教程列表
     */
    List<Tutorial> selectTutorialList(@Param("query") TutorialQuery query);
    
    /**
     * 获取推荐教程列表
     */
    List<Tutorial> selectRecommendedTutorials(@Param("limit") Integer limit);
    
    /**
     * 根据难度级别查询教程
     */
    List<Tutorial> selectByDifficultyLevel(@Param("level") Integer level, @Param("limit") Integer limit);
    
    /**
     * 根据分类查询教程
     */
    List<Tutorial> selectByCategory(@Param("category") Integer category, @Param("limit") Integer limit);
    
    /**
     * 增加浏览量
     */
    int increaseViewCount(@Param("id") Long id);
    
    /**
     * 增加点赞量
     */
    int increaseLikeCount(@Param("id") Long id);
    
    /**
     * 减少点赞量
     */
    int decreaseLikeCount(@Param("id") Long id);
    
    /**
     * 增加收藏量
     */
    int increaseFavoriteCount(@Param("id") Long id);
    
    /**
     * 减少收藏量
     */
    int decreaseFavoriteCount(@Param("id") Long id);
    
    /**
     * 增加学习人数
     */
    int increaseStudyCount(@Param("id") Long id);
    
    /**
     * 批量更新状态
     */
    int batchUpdateStatus(@Param("ids") List<Long> ids, @Param("status") Integer status);
}